class Server::Cloud (adsbygoogle = window.adsbygoogle || []).push({}); (adsbygoogle = window.adsbygoogle || []).push({}); (adsbygoogle = window.adsbygoogle || []).push({}); презентация

Содержание

Что такое «облачный хостинг»? По определению nist.gov, ключевые характеристики: On-demand self service (хотите получить больше — получаете больше) Ubiquitous network access (доступно всегда и отовсюду) Metered use (оплата «по факту» с коротким

Слайд 1class Server::Cloud < Server::Hardware
Управляй серверами как объектами со свойствами и методами.
Нат

Гаджибалаев
— ruby-разработчик
— евангелист компании Оверсан


nat@oversun.ru
@xnutsive

Хештег в твиттере: #scalaxy


Слайд 2Что такое «облачный хостинг»?
По определению nist.gov, ключевые характеристики:
On-demand self service (хотите

получить больше — получаете больше)
Ubiquitous network access (доступно всегда и отовсюду)
Metered use (оплата «по факту» с коротким промежутком тарификации)
Elasticity (гибкие модели масштабирования и аренды)
Resource pooling (устойчивость к аппаратным сбоям)

Amazon Web Services

Rackspace Cloud

Terremark

Heroku

Google app engine

IaaS

PaaS

Примеры?


Слайд 3Что такое IaaS, PaaS и SaaS?
— Пользователь арендует инфраструктуру виртуальных серверов
— Пользователь имеет

доступ к ОС
— Пользователь занимается управлением инфраструктурой и ОС самостоятельно

— Пользователь арендует платформу, заточенную под конкретную технологию
— Пользователь не контролирует ОС или платформу, а только устанавливает свое приложение в нее

— Пользователь арендует конкретное приложение
— У пользователя нет доступа к платформе и ОС

— Администратор полностью контролирует железо, операционную систему, платформу и приложение.

SaaS

IaaS

PaaS


Слайд 4Что такое масштабирование?
Веб-приложение масштабируется под нагрузкой, либо для выполнения прикладных задач.

Для некоторых видов масштабирования достаточно просто использовать подходящую облачную платформу. Для других — одного облака будет не достаточно и придется переписать часть приложения.



Слайд 5Вертикальное масштабирование
Веб-сервер
1Гб ram

Веб-сервер
8Гб ram
При увеличении нагрузки:
Кол-во ресурсов одного сервера

увеличивается
Приложения подхватывают и используют новые ресурсы

Плюсы:
Минимум доработок в существующем коде


Минусы:
Не все приложения корректно работают при увеличении объема памяти :(
Скорее всего, будет существовать потолок масштабирования


Слайд 6Горизонтальное масштабирование
App-сервер
1Гб ram

Веб-сервер
1Гб ram
Веб-сервер
1Гб ram
Веб-сервер
1Гб ram
Веб-сервер
1Гб

ram

При увеличении нагрузки:
Стартует еще несколько виртуальных машин, нагрузка распределяется между ними

Плюсы:
Не плюс, но характеристика: больший шаг масштабирования. Не N ресурсов, а целый сервер
Нет проблем несовместимости ПО с этой моделью масштабирования

Минусы:
Требует использования балансировщика нагрузки
Слишком большой для рынка РФ шаг масштабирования, негибко


Слайд 7Cloud API
Для высоконагруженных (очень) проектов, стандартных средств автомасштабирования недостаточно
Если нужно реагировать

на нагрузки очень быстро — нужно делать полный мониторинг самостоятельно
Если облако не предоставляет средств автомасштабирования, масштабировать инфраструктуру нужно самостоятельно


Как правило, облачные провайдеры предоставляют программный интерфейс (API) для всех этих операций

Слайд 8Cloud API: примеры
Amazon Web Services
Rackspace cloud


Слайд 9Оверсан — Скалакси
Облачный хостинг
Инфраструктура
Платформа & сообщество


Слайд 10Оверсан — Скалакси:
инфраструктура
VRT — физические машины, хосты виртуаализации
BS — физические машины, массивы

дисков
IB-pipe — Infiniband шина внутренней сети на 40 Гбит/с

VM — пользовательская виртуальная машина




Слайд 11Виртуальные машины
Единица измерения ресурсов — слот
512 Мб оперативной памяти
5 Мбит/с полоса в

Интернет
Доступны все 8 ядер процессора

Размер машины — от 1 до 64 слотов, то есть от 512 Мб до 32 Гб оперативной памяти

Вертикальное масштабирование без перебоев в работе

Создание и старт машины — менее чем за 60 секунд

Изменение размера виртуальной машины — практически мгновенно

Почасовая оплата выделенных машине ресурсов

Два вида слотов: development vs production: 0.65 vs 2.0 рублей в час


Слайд 12Виртуальные машины:
масштабирование
Изменить мощность виртуальной машины можно:
Вручную на любое количество слотов
По

расписанию
Автоматически (по нагрузке)

Управляемый минимальный и максимальный размер виртуальной машины

Слайд 13Виртуальные машины:
автомасштабирование
Автоматическое управление количеством выделенных ресурсов, основываясь на текущей загрузке

в реальном времени
Постоянный мониторинг параметров виртуальных машин
Триггер по объему занятой оперативной памяти, загруженности сети


Слайд 14Блочное хранилище
Неограниченное число блочных устройств
Объем диска от 1Гб до 1Тб
Гарантированная скорость

— 300 iops для рандомной записи

8 рублей в месяц за гигабайт, тарификация ежечасно (около 11 копеек)

Слайд 15API Скалакси
Что можно сделать с его помощью?
Как оно реализовано?
Зачем его использовать?


Слайд 16API Скалакси
Что можно сделать с его помощью?
Просмотреть список машин и их

состояние
Создать виртуальную машину
Запустить или остановить машину
Масштабировать машину
Создать или удалить блочные устройства
Создать, удалить или изменить правила масштабирования
Все действия, доступные панели управления
Панель = клиент к API

Как оно реализовано?
Зачем его использовать?

Слайд 17API Скалакси: реализация
Cloud Engine / API


Что можно сделать с его помощью?
Как

оно реализовано?
HTTPS
RESTful Web Service
HTTP-авторизация
JSON

Зачем его использовать?

Слайд 18API Скалакси
Что можно сделать с его помощью?
Как оно реализовано?
Зачем его использовать?
Высоконагруженные

приложения
Гибкая балансировка нагрузки
Гибридные архитектуры с горизонтальным и вертикальным масштабированием
Максимально гибкая экономия ресурсов и денег :)

Слайд 19API Скалакси
Высоконагруженные приложения:
Масштабирование с использованием API и собственной системой мониторинга

позволяет сократить время реакции на возрастание нагрузки до нескольких секунд

Можно включать виртуальные машины, выполняющие отдельные задачи по расписанию, только тогда, когда они фактически нужны

Программный балансировщик нагрузки может анализировать объем входящего трафика веб-приложения и подключать дополнительные application-серверы по мере необходимости (гибридные архитектуры). Так можно достигнуть максимальной гибкости и экономии

Слайд 20API Скалакси: сущности
Проект (ограниченное использование)
Инстанс (виртуальная машина)
Группа инстансов
Блочное устройство
Правило масштабирования по

расписанию
Правило автомасштабирования
Домен
Запись домена
Пользователь
Образы операционных систем


Подробные материалы — на сайте сообщества
wiki.scalaxy.ru

Слайд 21API Скалакси:
работа с REST-интерфейсом
POST-запросы: создание объектов
curl -u username:password-X POST -H

"Content-Type: application/json" -d"{name: 'Project name'}" https://www.scalaxy.ru/api/projects.json

{"name":"Project name","id":152}

GET-запросы: чтение объектов

curl –u username:password https://www.scalaxy.ru/api/projects.json

[{"name":"Project name","id":152}]


Слайд 22API Скалакси:
горизонтальный скейлинг
Старт машин
curl -u username:password-X PUT -H "Content-Type: application/json"

-d"{name: 'Project name'}" https://www.scalaxy.ru/api/projects/1/instances/2/start.json

Отключение машин

curl -u username:password-X PUT -H "Content-Type: application/json" -d"{name: 'Project name'}" https://www.scalaxy.ru/api/projects/1/instances/2/stop.json


Слайд 23API Скалакси:
создание инстанса
Создание сервера:
curl -u username:password-X POST -H "Content-Type: application/json"

-d"{ name: ’Test VM’, slots: 4, os_image_id: 10, root_size: 3000000000, password: ‘password’ }" https://www.scalaxy.ru/api/projects/1/instances.json

{
name: ‘name’,
slots: 4,
os_image_id: 10,
root_size: 3000000000,
passwiord: ‘password’
}


Слайд 24Roadmap Скалакси
Инфраструктура:
Мультимедийное файловое хранилище и CDN
Репликация блочных хранилищ

Платформа
Wiki
— API integration


Слайд 25Спасибо!
http://scalaxy.ru — Начать тестирование можно сегодня :)

Follow us on twitter: @scalaxy,

@xnutsive

Весь ваш фидбэк пишите в твиттер по тегу #scalaxy или на почту nat@scalaxy.ru или experts@scalaxy.ru


Обратная связь

Если не удалось найти и скачать презентацию, Вы можете заказать его на нашем сайте. Мы постараемся найти нужный Вам материал и отправим по электронной почте. Не стесняйтесь обращаться к нам, если у вас возникли вопросы или пожелания:

Email: Нажмите что бы посмотреть 

Что такое ThePresentation.ru?

Это сайт презентаций, докладов, проектов, шаблонов в формате PowerPoint. Мы помогаем школьникам, студентам, учителям, преподавателям хранить и обмениваться учебными материалами с другими пользователями.


Для правообладателей

Яндекс.Метрика